package com.cucn.ingmall.ware.dao;

import com.cucn.ingmall.ware.entity.WareSkuEntity;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;

import java.util.List;

/**
 * 商品库存
 *
 * @author kouchaojie
 * @email kou1688@foxmail.com
 * @date 2021-11-17 18:35:22
 */
@Mapper
public interface WareSkuDao extends BaseMapper<WareSkuEntity> {
    /**
     * 将采购人员采购的商品入库
     *
     * @param skuId  skuId
     * @param wareId 仓库id
     * @param skuNum sku的数量
     */
    void addStock(@Param("skuId") Long skuId, @Param("wareId") Long wareId, @Param("skuNum") Integer skuNum);

    /**
     * 查询sku的库存数
     *
     * @param skuId skuId
     * @return sku的库存数
     */
    Integer getSkuStock(Long skuId);

    /**
     * @param skuId
     * @return
     */
    List<Long> selectWareSkuHasStock(@Param("skuId") Long skuId);

    /**
     * 锁定库存
     *
     * @param skuId
     * @param wareId
     * @param lockNum
     */
    Integer lockStock(@Param("skuId") Long skuId, @Param("wareId") Long wareId, @Param("lockNum") Integer lockNum);

    Integer unLockStock(@Param("skuId") Long skuId, @Param("wareId") Long wareId, @Param("num") Integer num);

    /**
     * 查询skuName
     *
     * @param skuId skuId
     * @return skuName
     */
    //String getSkuNameBySkuId(Long skuId);
}
